import {
  createRouter,
  createWebHistory,
  RouteRecordRaw,
  createWebHashHistory,
  Router,
} from 'vue-router'
import Layout from '@/layout/index.vue'
// 扩展继承属性
interface extendRoute {
  hidden?: boolean
}
// 异步组件
export const asyncRoutes = [
  // ...userRouter,
  // ...patientRouter,
  // ...sportRouter,
  // ...systemRouter,
]

/**
 * path ==> 路由路径
 * name ==> 路由名称
 * component ==> 路由组件
 * redirect ==> 路由重定向
 * alwaysShow ==> 如果设置为true，将始终显示根菜单，无论其子路由长度如何
 * hidden ==> 如果“hidden:true”不会显示在侧边栏中（默认值为false）
 * keepAlive ==> 设为true 缓存
 * meta ==> 路由元信息
 * meta.title ==> 路由标题
 * meta.icon ==> 菜单icon
 * meta.affix ==> 如果设置为true将会出现在 标签栏中
 * meta.breadcrumb ==> 如果设置为false，该项将隐藏在breadcrumb中（默认值为true）
 */

export const constantRoutes: Array<RouteRecordRaw & extendRoute> = [
  {
    path: '/403',
    name: '403',
    component: () => import('@/views/errorPages/403.vue'),
    hidden: true,
  },
  {
    path: '/404',
    name: '404',
    component: () => import('@/views/errorPages/404.vue'),
    hidden: true,
  },
  {
    path: '/login',
    name: 'Login',
    component: () => import('@/views/login/index.vue'),
    hidden: true,
    meta: { title: '登录', login: false },
  },
  {
    path: '/',
    name: 'layout',
    component: Layout,
    redirect: '/',
    meta: { title: '首页', icon: 'House', login: false },
    children: [
      {
        path: '/',
        component: () => import('@/views/home/index.vue'),
        name: 'home',
        meta: { title: '首页', icon: 'House', affix: true, role: ['other'], login: false },
      },
      {
        path: '/list',
        component: () => import('@/views/list/index.vue'),
        name: 'list',
        meta: { title: '编辑', icon: 'House', affix: true, role: ['other'], login: true },
      },
      {
        path: '/edit',
        component: () => import('@/views/list/edit.vue'),
        name: 'edit',
        meta: { title: '编辑', icon: 'House', affix: true, role: ['other'], login: true },
      },
    ],
  },
]

/**
 * notFoundRouter(找不到路由)
 */
export const notFoundRouter = {
  path: '/:pathMatch(.*)',
  name: 'notFound',
  redirect: '/404',
}

const router = createRouter({
  history: createWebHistory(process.env.VITE_BASE_URL), // history
  // history: createWebHashHistory(), // hash
  routes: constantRoutes,
})

export default router
